**Lab Experiment-3**

**Title of the Experiment:** To design and Verify **4- Bit Binary Adder and Subtractor** using Verilog code and compare with their respective truth tables.

**Objective/Motivation:** In this lab, Adder - Subtractor circuit is designed and which is arithmetic digital circuit that can perform both addition and subtraction using only one n-bit adder, no separate circuit for addition or subtraction is required. The objective will be to test these designs on Xilinx simulation tool. The tests will be performed for all the possible combinations of inputs to verify their functionality. Moreover, the knowledge gained will be used to design much larger and complex logic designs.

**Equipment required:**

|  |  |  |  |
| --- | --- | --- | --- |
| **S No** | **Name of The Components/Tool** | **Version** | **Quantity** |
| 1. | Xilinx Vivado Design Suite **/** EDA play Ground software | V23.1 | 1 |
| 2. | Zybo board | Zynq XC7Z010 | 1 |
| 3. | Personal Computer | - | 1 |

**Logic diagram(s) and Truth tables:**

|  |  |
| --- | --- |
| **Logic Circuit name** | **Logic Diagram** |
| **Half Adder** |  |

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| **Logic Circuit name** | **Truth Table** | | | | | | |
| **4 Bit binary Adder-Subtractor** |  | **Full Adder Input** | | | | **Output** | |
| When Adding | | | | | | |
| **Crtl /a\_s** | **a**  **(DE=6)** | B  (DE=4) | Bmod | C / a\_s | Sum | Carry |
| 0 | **0** | 0 | **0** | 0 | **1** | **c1= 0** |
| **1** | 1 | **1** | **c1= 0** | **0** | **c2=0** |
| **1** | 0 | **0** | **c2=0** | **1** | **c3=0** |
| **0** | 0 | **0** | **c3=0** | **0** | **Carry(c4)=0** |
| **When Subtracting** | | | | | | |
| **Crtl /a\_s** | **a**  **(DE=6)** | B  (DE=4) | Bmod | **Barrow / a\_s** | **Diff** | **Barrow** |
| 1 | **0** | 0 | **1** | c=a\_s=1 | **0** | b1=1 |
| **1** | 1 | **0** | b1=1 | **0** | b2=1 |
| **1** | 0 | **1** | b2=1 | **1** | b3=1 |
| **0** | 0 | **1** | b3=1 | **0** | **Barrow(b4)=1** |
| * When **Crtl /a\_s =0**, then Full Adder performs Addition, **Crtl /a\_s =1** then Full Adder performs subtraction**.** * B is connected to the one input of n-bit ex-or gates and 2nd input is ctrl or a\_s. So wire **Bmod** is **B** when input **a\_s / CTRL** is **0**. Wire **Bmod** is **complement of B** if **a\_s / CTRL** is 1. * **Sum\_diff =a^bmod^a\_s** * **carry=(a&b)|(b&a\_s)|(a\_s&a);** * **barrow=(~(a)&b)|(b&a\_s)|(a\_s&~(a));** * For initial bit Operation of Addition / Subtraction, a\_s= Ctrl, but from 2nd bit operation onwards a\_s=c1,c2,c3 in addition, a\_s= b1,b2,b3 in subtraction. | | | | | | |

**Operational Summary:**

* 4-bit Binary Adder-Subtractor circuit is the **arithmetic digital circuit**, which can perform both addition and subtraction **using only one n-bit adder**, no separate circuit for addition or subtraction is required.
* The logic of the circuit is that, we can represent a negative number in 2's complement number system by taking it's complemented and then adding 1 into it. So, if we want wo perform operation y = A - B, we can perform y = A + (-B) and the result is same y = A - B. So, we require only adder to perform subtraction operation if we can convert positive input to the negative input.

![](data:image/png;base64,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)

* We need to implement an adder. Let's use n-bit [Ripple Carry Adder](https://circuitfever.com/ripple-carry-adder-verilog-code) for this. Now, only we need to write code to implement the n-bit inverter to make one input negative number. If carry in (Cin) is logic 1 and one number is negative, the adder will compute y = A-B. If carry in is logic zero and both the number is same as the input, then it computer y = A + B.
* The complete Verilog code for n-bit adder-subtractor circuit is given above. There are two inputs numbers A, B and one input (**a\_s / CTRL**) **for performing adder/subtraction**.
* Initially, the input **a\_s / CTRL** is connected to the cin and ex-or gate 2nd input of the ripple carry adder.
* A is directly connected to the input A of ripple carry adder and
* B is connected to the one input of n-bit ex-or gates. So wire **Bmod** is **B** when input **a\_s / CTRL** is **0**. Wire **Bmod** is **complement of B** if **a\_s / CTRL** is 1.

**Verilog Source Code for 4- Bit Binary Adder and Binary Subtractor** **in various Models or various Level of Abstrction:**

|  |  |  |
| --- | --- | --- |
| **Gate name** | **Data Flow Model** | **Test Bench** |
| **4- Bit Binary Adder and Binary Subtractor** | //Full Adder  module full\_adder(a,b,a\_s,sum,carry);  input a,b,a\_s;  output sum,carry;  assign sum=a^b^a\_s;  assign carry=(a&b)|(b&a\_s)|(a\_s&a);  endmodule  //rca(ripple carry adder)  **module rca(input [3:0]a,b,input a\_s,output [3:0]sum,output c4);**  **wire c1,c2,c3; //Carry out of each full adder**  **full\_adder fa0(a[0],b[0],a\_s,sum[0],c1);**  **full\_adder fa1(a[1],b[1],c1,sum[1],c2);**  **full\_adder fa2(a[2],b[2],c2,sum[2],c3);**  **full\_adder fa3(a[3],b[3],c3,sum[3],c4);**  **endmodule**  //fbbas (4-Bit binary Adder Subtractor)  **module fbbas\_d(input a\_s,input [3:0]a,b,output [3:0]sum\_diff,output c4\_b4);**  **wire [3:0]Bmod;**  **assign Bmod={4{a\_s}}^b;**  **rca rca0(a,Bmod,a\_s,sum\_diff,c4\_b4);**  **endmodule** | **//fbbas (4-Bit binary Adder Subtractor)-Test Bench**  **module fbbas\_d\_tb();**  **reg a\_s;**  **reg [3:0]a,b;**  **wire [3:0]sum\_diff;**  **wire c4\_b4;**  **fbbas\_d uut(a\_s,a,b,sum\_diff,c4\_b4);**  **initial begin**  **a=4'b0110;**  **b=4'b0100;**  a\_s = 0; //Addition  #20  a\_s = 1; //Subtraction  #20  $stop();  end  endmodule |

**Observation / Output Waveforms:**

**Result:** The simulation waveforms are obtained with various input combination of binary data and Control logic pin (**CTRL /a\_s**) and verified with the truth table data.